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DETAILED ACTION 



Claim Rejections - 35 USC § 103 

1 . The following is a quotation of 35 U.S.C. 1 03(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

Referring to claim 1 

2. Claims 1, 3, 5, 7, 14,15, 17,19 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Ang (US 2004/0221 127 A1 ) in view of Luick (US 2003/01 77335 A1 ) 
further in view of Biber ( US 4,951 ,278) further in view of Aztmony ( US 7,395,283 B1 ) 

Referring to claim 1 Ang discloses An inter-computer data transfer method for 
transferring data between a plurality of computers each including a main storage device 
i.e. memory controller ([0008] These addresses are then stored in a table which is 
accessed by the memory controller in order to convert virtual addresses to physical 
addresses). , A processor i.e. microprocessor for issuing a communication process 
command and a communication device i.e. peripheral device (in this case Ethernet 
card) for processing the communication command from said processor and 
communicating with another one of said computers through a switched network (Pg. 1 
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[0005] This is particularly important in a symmetric multiprocessing (SMP) environment, 
where multiple processors have access to and share the same common centralized 
main memory system). , comprising the step of: each of a transmission section and a 
reception section of said communication device including a translation look aside buffer 
for retaining a plurality of translation look aside buffer entries (Pg. 2 [0019] In a 
preferred embodiment, the microprocessor include an extended version of a 
conventional translation look-aside buffer (TLB). Like a conventional TLB, the TLB in 
this invention contains a subset of all mapping from the virtual addresses in the memory 
to their corresponding physical memory address locations. In a preferred embodiment, 
each entry in the TLB includes fields to track whether the page represented by the entry 
is pinned, and the number of times the page has been pinned. Utilizing the TLB, the 
microprocessor enables user-level code to convert virtual addresses to physical 
addresses, pin the associated page and convey the physical address to a peripheral 
device, without making any system calls. The physical address resulting from the 
translation is conveyed to a peripheral device via bus transactions wherein the address 
portion of each bus transaction specifies the peripheral device, while the data portion of 
each bus transaction holds the result of an address translation (i.e. the physical address 
where the memory access is to occur). As physical addresses are conveyed, the 
corresponding page in the memory is "pinned". This is reflected in the TLB, as well as 
the main page table in the main memory.); Ang did not discloses determining, when a 
communication command including information of that one of the computers which is a 
sending source is issued from said processor, one of the translation look aside buffer 
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entries which is to be used in accordance with the computer of the sending source by 
means of said reception section. The general concept of determining, when a 
communication command including information of that one of the computers which is a 
sending source is issued from said processor, one of the translation look aside buffer 
entries which is to be used in accordance with the computer of the sending source by 
means of said reception section is well known in the art as taught by Luick. Luick 
discloses determining, when a communication command including information of that 
one of the computers which is a sending source is issued from said processor (Pg. 1 
[0009] Most modern processors employ some form of pipelining to increase the average 
number of operations executed per clock cycle, as well as one or more levels of cache 
memory to provide high-speed access to a subset of data in main memory. Pipelined 
instruction execution allows subsequent instructions to begin execution before 
previously issued instructions have finished. Ideally, a new instruction begins with each 
clock cycle, and subsequently moves through a pipeline stage with each cycle. Even 
though an instruction may take multiple cycles or pipeline stages to complete, if the 
pipeline is always full, the processor executes one instruction every cycle.), one of the 
translation look aside buffer entries which is to be used in accordance with the computer 
of the sending source by means of said reception section (Pg. 1 [0013] Typically, in 
order to obtain a real address of data for a data reference operation (e.g., a load or 
store operation), a portion of the virtual address is used to access a table called a 
translation look aside buffer (TLB). The TLB is typically N-way set associative, providing 
N possible real address entries corresponding to the virtual address. A TLB lookup 
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requires that the N entries be retrieved from the TLB, that each entry be compared to 
the virtual address, and that the real address corresponding to the matched entry be 
selected. These operations may require multiple clock cycles). It would have been 
obvious to one of ordinary skill in the art at the time of the invention to modify Ang to 
include determining, when a communication command including information of that one 
of the computers which is a sending source is issued from said processor, one of the 
translation look aside buffer entries which is to be used in accordance with the computer 
of the sending source by means of said reception section in order to improved 
techniques for dealing with pipeline address conflicts. 

Luick did not disclose wherein the communication command further includes a 
destination computer number, a destination process number, a destination logical 
address, a transfer length, a sending source computer number, a sending source 
process number, and a sending source logical address, and wherein the communication 
command is transmitted divisionally in a plurality of communication packets over the 
switched network, in order to assure reliability of communication. The general concept 
of wherein the communication command further includes a destination computer 
number, a destination process number, a destination logical address, a transfer length, 
a sending source computer number, a sending source process number, and a sending 
source logical address, and wherein the communication command is transmitted 
divisionally in a plurality of communication packets over the switched network, in order 
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to assure reliability of communication is well known in the art as taught by Atzony. 
Atzmony discloses wherein the communication command further includes a destination 
computer number, a destination process number, a destination logical address, a 
transfer length, a sending source computer number, a sending source process number, 
and a sending source logical address, and wherein the communication command is 
transmitted divisionally in a plurality of communication packets over the switched 
network, in order to assure reliability of communication (Col. 7 lines 56-64 Assuming 
verification, control passes to step 124 wherein the host adapter locks the destination 
logical device, such as the destination logical device 40A. In step 125 the host adapter 
controller 86 places an ATTN signal in a request buffer for the source logical device, 
such as an ATTN flag in the header 51 . Step 126 forms the request record for effecting 
the data transfer to the destination logical device. The request record includes the 
source logical device number and the destination logical device number.) It would have 
been obvious to one of ordinary skill in the art at the time of the invention to modify Ang 
to include wherein the communication command further includes a destination computer 
number, a destination process number, a destination logical address, a transfer length, 
a sending source computer number, a sending source process number, and a sending 
source logical address, and wherein the communication command is transmitted 
divisionally in a plurality of communication packets over the switched network, in order 
to assure reliability of communication in order to improved techniques for dealing with 
pipeline address conflicts. 
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Referring to claim 15 

Claim 15 is similarly rejected using at least the same reasoning /citations provided 
above for claim 1 similarly they recite the same limitations and are distinguished only by 
statutory category. 

Referring to claim 3 

3. Referring to claim 3 Ang Luick, and Atzmony disclose all the limitations of claim 3 
which is described above. Ang also discloses wherein the number of communication 
commands to be processed simultaneously to the same destination computer from the 
computer of the sending source is limited by said communication device (Pg.9 [0064] 
The number of pages which may be pinned down by any single user-level job or 
process, as well as the total number of pages which may be pinned down, is preferably 
capped at operator programmable levels. In a preferred embodiment of the present 
invention, an attempt to translate a virtual address to a to physical address i and pin 
down the associated page in the memory will fail if either of these two counters is 
already at its maximum value. Accordingly, before any Trans_and_pin or 
Trans_and_pin_only transaction is complete, the counters are checked to see if they 
are at their maximum allowable value. If so, the physical addresses are not passed to 
the peripheral device or to the physical address register and the pages are not pinned 
down. Instead, the failure status of executing the trans_and_pin instruction is reflected 
in the <outcome> field of the instruction). 
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Referring to claim 17 

Claim 17 is similarly rejected using at least the same reasoning /citations provided 
above for claim 3 similarly they recite the same limitations and are distinguished only by 
statutory category. 



Referring to claim 5 

Referring to claim 5 Ang discloses An inter-computer network system, comprising: a 
plurality of computers connected to each other; each of said computers including a main 
storage device, i.e. memory controller ([0008] These addresses are then stored in a 
table which is accessed by the memory controller in order to convert virtual addresses 
to physical addresses). A processor i.e. microprocessor for issuing a communication 
processing command, and a communication device i.e. peripheral device (in this case 
Ethernet card) for processing the communication command from said processor and 
communicating with another one of said computers through said switching network; said 
communication device including a transmission section for transmitting a 
communication to and a reception section for receiving a communication to said 
switched network (Pg. 2 [0010] The invention includes a memory system and a set of 
user-level instructions, i.e. instructions that are callable from user-level code, for 
converting virtual addresses to physical, addresses without requiring a system call. In a 
preferred embodiment of the invention, the memory system includes a memory, a 
memory controller, a microprocessor, and one or more peripheral devices. In a 
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preferred embodiment, the system of the present invention uses an extended version of 
a conventional translation look-aside buffer (TLB) implemented in the microprocessor to 
allow user-level code running on the microprocessor to convert virtual addresses to 
physical addresses, pin the associated page, and convey the physical address to a 
peripheral device, without making any system calls. The result of the translation is 
conveyed to a peripheral device via a bus transaction wherein the address portion of the 
bus transaction targets the peripheral device, while the data portion of the bus 
transaction holds the result of the translation (i.e. the physical address where the 
memory access is to occur). The system further allows user-level code to unpin a 
previously pinned page once the peripheral access has completed.); each of said 
transmission section and said reception section including a translation look aside buffer 
for retaining a plurality of translation look aside buffer entries (Pg. 2 [0019] The 
microprocessor include an extended version of a conventional translation look-aside 
buffer (TLB). Like a conventional TLB, the TLB in this invention contains a subset of all 
mapping from the virtual addresses in the memory to their corresponding physical 
memory address locations. In a preferred embodiment, each entry in the TLB includes 
fields to track whether the page represented by the entry is pinned, and the number of 
times the page has been pinned. Utilizing the TLB.). Ang did not discloses processor 
issuing the communication command which includes information of that one of the 
computers which is a sending source; said reception section determining one of the 
translation look aside buffer entries which is to be used in accordance with the computer 
of the sending source. The general concept of processor issuing the communication 
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command which includes information of that one of the computers which is a sending 
source; said reception section determining one of the translation look aside buffer 
entries which is to be used in accordance with the computer of the sending source is 
well known in the art as taught by Luick. Luick discloses processor issuing the 
communication command which includes information of that one of the computers which 
is a sending source (Pg. 1 [0009] Most modern processors employ some form of 
pipelining to increase the average number of operations executed per clock cycle, as 
well as one or more levels of cache memory to provide high-speed access to a subset 
of data in main memory. Pipelined instruction execution allows subsequent instructions 
to begin execution before previously issued instructions have finished. Ideally, a new 
instruction begins with each clock cycle, and subsequently moves through a pipeline 
stage with each cycle. Even though an instruction may take multiple cycles or pipeline 
stages to complete, if the pipeline is always full, the processor executes one instruction 
every cycle.); said reception section determining one of the translation look aside buffer 
entries which is to be used in accordance with the computer of the sending source (Pg. 
1 [0013] Typically, in order to obtain a real address of data for a data reference operation 
(e.g., a load or store operation), a portion of the virtual address is used to access a table 
called a translation look aside buffer (TLB). The TLB is typically N-way set associative, 
providing N possible real address entries corresponding to the virtual address. A TLB 
lookup requires that the N entries be retrieved from the TLB, that each entry be 
compared to the virtual address, and that the real address corresponding to the 
matched entry be selected. These operations may require multiple clock cycles). It 
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would have been obvious to one of ordinary skill in the art at the time of the invention to 
modify Ang to include processor issuing the communication command which includes 
information of that one of the computers which is a sending source; said reception 
section determining one of the translation look aside buffer entries which is to be used 
in accordance with the computer of the sending source in order to improved techniques 
for dealing with pipeline address conflicts. 

Luick did not disclose wherein the communication command further includes a 
destination computer number, a destination process number, a destination logical 
address, a transfer length, a sending source computer number, a sending source 
process number, and a sending source logical address, and wherein the communication 
command is transmitted divisionally in a plurality of communication packets over the 
switched network, in order to assure reliability of communication. The general concept 
of wherein the communication command further includes a destination computer 
number, a destination process number, a destination logical address, a transfer length, 
a sending source computer number, a sending source process number, and a sending 
source logical address, and wherein the communication command is transmitted 
divisionally in a plurality of communication packets over the switched network, in order 
to assure reliability of communication is well known in the art as taught by Atzmony. 
Atzmony discloses wherein the communication command further includes a destination 
computer number, a destination process number, a destination logical address, a 
transfer length, a sending source computer number, a sending source process number, 
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and a sending source logical address, and wherein the communication command is 
transmitted divisionally in a plurality of communication packets over the switched 
network, in order to assure reliability of communication (Col. 7 lines 56-64 Assuming 
verification, control passes to step 124 wherein the host adapter locks the destination 
logical device, such as the destination logical device 40A. In step 125 the host adapter 
controller 86 places an ATTN signal in a request buffer for the source logical device, 
such as an ATTN flag in the header 51 . Step 126 forms the request record for effecting 
the data transfer to the destination logical device. The request record includes the 
source logical device number and the destination logical device number.) It would have 
been obvios to one of ordinary skill in the art at the time of the invention to modify Ang 
to include wherein the communication command further includes a destination computer 
number, a destination process number, a destination logical address, a transfer length, 
a sending source computer number, a sending source process number, and a sending 
source logical address, and wherein the communication command is transmitted 
divisionally in a plurality of communication packets over the switched network, in order 
to assure reliability of communication in order to improved techniques for dealing with 
pipeline address conflicts. 

Referring to claim 19 

Claim 19 is similarly rejected using at least the same reasoning /citations provided 
above for claim 5 similarly they recite the same limitations and are distinguished only by 
statutory category. 
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Referring to claim 7 

Referring to claim 7 Ang, Luick, Atzmony discloses all the limitations of claim 7 which is 
described above. Ang also discloses wherein said communication apparatus limits the 
number of communication commands to be processed simultaneously to the same 
destination computer from the computer of the sending source. (Pg.9 [0064] The 
number of pages which may be pinned down by any single user-level job or process, as 
well as the total number of pages which may be pinned down, is preferably capped at 
operator programmable levels. In a preferred embodiment of the present invention, an 
attempt to translate a virtual address to a to physical address i and pin down the 
associated page in the memory will fail if either of these two counters is already at its 
maximum value. Accordingly, before any Trans_and_pin or Trans_and_pin_only 
transaction is complete, the counters are checked to see if they are at their maximum 
allowable value. If so, the physical addresses are not passed to the peripheral device or 
to the physical address register and the pages are not pinned down. Instead, the failure 
status of executing the trans_and_pin instruction is reflected in the <outcome> field of 
the instruction). 

Regarding claim 14 

Referring to claim 14 Ang, Luick, and Atzmony discloses all the limitations of claim 13 
which is described above. Ang also discloses means for suppressing a number of 
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communication commands to be processed simultaneously to a same destination. (Pg. 
2 [0010] The invention includes a memory system and a set of user-level instructions, 
i.e. instructions that are callable from user-level code, for converting virtual addresses to 
physical, addresses without requiring a system call. In a preferred embodiment of the 
invention, the memory system includes a memory, a memory controller, a 
microprocessor, and one or more peripheral devices. In a preferred embodiment, the 
system of the present invention uses an extended version of a conventional translation 
look-aside buffer (TLB) implemented in the microprocessor to allow user-level code 
running on the microprocessor to convert virtual addresses to physical addresses, pin 
the associated page, and convey the physical address to a peripheral device, without 
making any system calls. The result of the translation is conveyed to a peripheral device 
via a bus transaction wherein the address portion of the bus transaction targets the 
peripheral device, while the data portion of the bus transaction holds the result of the 
translation (i.e. the physical address where the memory access is to occur). The system 
further allows user-level code to unpin a previously pinned page once the peripheral 
access has completed.) 

4. Claims 2,4,6,8,9,10, 11,12,13 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Ang (US 2004/0221 127 A1) in view of Luick (US 2003/0177335 A1) 
in view of Atzmony (US 7,395,283 B1) further in view of Hayes (US 5,497,480). 
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Referring to claim 2 

Referring to claim 2, Ang, Luick, Atzmony disclose all the limitations of claim 2 which is 
described above. Ang did not disclose wherein said transmission section of said 
communication device produces a communication packet including the information of 
the computer of the sending source and transmits the communication packet to another 
one of said computers. The general concept of transmission section of said 
communication device produces a communication packet including the information of 
the computer of the sending source and transmits the communication packet to another 
one of said computers is well known in the art as taught by Hayes. Hayes discloses 
transmission section of said communication device produces a communication packet 
including the information of the computer of the sending source and transmits the 
communication packet to another one of said computers (Col. 2 lines 23-34 A method 
and apparatus for removing a page table entry from a plurality of translation look aside 
buffers ("TLB's") coupled to a plurality of processors in a multiprocessor system is 
disclosed. The method comprises the steps of issuing a request packet by a first 
controller of the first TLB to remove the page table entry from the first TLB; sending the 
request packet to the packet-switched bus to be broadcast to a second controller 
coupled to a second TLB with the request packet specifying a predetermined source, 
the first address mode and process identification; receiving the request packet by the 
second controller on the packet-switched bus). It would have been obvious to one of 
ordinary skill in the art at the time of the invention to modify Ang to include transmission 
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section of said communication device produces a communication packet including the 
information of the computer of the sending source and transmits the communication 
packet to another one of said computers in order to provide a broadcast page removal 
scheme for all the processors on a multiprocessor computer system. 

Referring to claim 16 and Claim 20 

Claims 16 and 20 are similarly rejected using at least the same reasoning /citations 
provided above for claim 2 similarly they recite the same limitations and are 
distinguished only by statutory category. 

Referring to claim 4 

Referring to claim 4 Ang, Luick, Atzmony disclose all the limitations of claim 4 which is 
described above. Ang did not disclose wherein an identification number of a processing 
command in the computer of the sending source is applied to a communication packet 
by said communication device, and for different communication packets which have the 
same identification number of the processing command, the same translation look aside 
buffer entry is used by said reception section of said communication device. The 
general concept of wherein an identification number of a processing command in the 
computer of the sending source is applied to a communication packet by said 
communication device, and for different communication packets which have the same 
identification number of the processing command, the same translation look aside buffer 
entry is used by said reception section of said communication device is well known in 
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the art as taught by Hayes. Hayes discloses wherein an identification number i.e. TLB 
entry of a processing command in the computer of the sending source is applied to a 
communication packet by said communication device, and for different communication 
packets which have the same identification number of the processing command, the 
same translation look aside buffer entry is used by said reception 10 section of said 
communication device (Col. 2 lines 23-34 A method and apparatus for removing a page 
table entry from a plurality of translation look aside buffers ("TLB's") coupled to a 
plurality of processors in a multiprocessor system is disclosed. The method comprises 
the steps of issuing a request packet by a first controller of the first TLB to remove the 
page table entry from the first TLB; sending the request packet to the packet-switched 
bus to be broadcast to a second controller coupled to a second TLB with the request 
packet specifying a predetermined source, the first address mode and process 
identification; receiving the request packet by the second controller on the packet- 
switched bus). It would have been obvious to one of ordinary skill in the art at the time 
of the invention to modify Ang to include wherein an identification number of a 
processing command in the computer of the sending source is applied to a 
communication packet by said communication device, and for different communication 
packets which have the same identification number of the processing command, the 
same translation look aside buffer entry is used by said reception section of said 
communication device in order to provide a broadcast page removal scheme for all the 
processors on a multiprocessor computer system. 
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Referring to claim 18 

Claim 18 is similarly rejected using at least the same reasoning /citations provided 
above for claim 4 similarly they recite the same limitations and are distinguished only by 
statutory category. 

Referring to claim 6 

Referring to claim 6 Ang, Luick, and Atzmony disclose all the limitations of claim 6 
which is described above. Ang did not disclose wherein said transmission section 
produces a communication packet including the information of the computer of the 
sending source and transmits the communication packet to another one of said 
computers. The general concept of transmission section produces a communication 
packet including the information of the computer of the sending source and transmits 
the communication packet to another one of said computers is well known in the art as 
taught by Hayes. Hayes discloses transmission section produces a communication 
packet including the information of the computer of the sending source and transmits 
the communication packet to another one of said computers. (Col. 2 lines 23-34 A 
method and apparatus for removing a page table entry from a plurality of translation 
look aside buffers ("TLB's") coupled to a plurality of processors in a multiprocessor 
system is disclosed. The method comprises the steps of issuing a request packet by a 
first controller of the first TLB to remove the page table entry from the first TLB; sending 
the request packet to the packet-switched bus to be broadcast to a second controller 
coupled to a second TLB with the request packet specifying a predetermined source, 
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the first address mode and process identification; receiving the request packet by the 
second controller on the packet-switched bus). It would have been obvious to one of 
ordinary skill in the art at the time of the invention to modify Ang to include transmission 
section produces a communication packet including the information of the computer of 
the sending source and transmits the communication packet to another one of said 
computers in order to provide a broadcast page removal scheme for all the processors 
on a multiprocessor computer system. 

Referring to claim 8 

Referring to claim 8 Ang, Luick, and Atzmony disclose all the limitations of claim 8 
which is described above. Ang did not disclose wherein said communication apparatus 
applies an identification number of a processing command in the computer of the 
sending source to a communication packet, and said reception section uses the same 
translation look aside buffer entry for different communication packets which have the 
same identification number of the processing command. The general concept of 
communication apparatus applies an identification number of a processing command in 
the computer of the sending source to a communication packet, and said reception 
section uses the same translation look aside buffer entry for different communication 
packets which have the same identification number of the processing command is well 
known in the art as taught by Hayes. Hayes discloses wherein said communication 
apparatus applies an identification number of a processing command in the computer of 
the sending source to a communication packet, and said reception section uses the 
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same translation look aside buffer entry for different communication packets which have 
the same identification number of the processing command. (Col. 2 lines 23-34 A 
method and apparatus for removing a page table entry from a plurality of translation 
look aside buffers ("Tab's") coupled to a plurality of processors in a multiprocessor 
system is disclosed. The method comprises the steps of issuing a request packet by a 
first controller of the first TLB to remove the page table entry from the first TLB; sending 
the request packet to the packet-switched bus to be broadcast to a second controller 
coupled to a second TLB with the request packet specifying a predetermined source, 
the first address mode and process identification; receiving the request packet by the 
second controller on the packet-switched bus). It would have been obvious to one of 
ordinary skill in the art at the time of the invention to modify Nag to include 
communication apparatus applies an identification number of a processing command in 
the computer of the sending source to a communication packet, and said reception 
section uses the same translation look aside buffer entry for different communication 
packets which have the same identification number of the processing command in order 
to provide a broadcast page removal scheme for all the processors on a multiprocessor 
computer system. 

Referring to claim 9 

Referring to claim 9 Ang, Luick, and Atzmony discloses all the limitations of claim 9 
which is described above. Ang also discloses transmission section of said 
communication device extracts a communication command from said main storage 
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device in accordance with an instruction from said processor (Pg.1 [0006] a 
microprocessor may execute user-level code which requires an Ethernet/network card 
to retrieve some data from several different virtual address locations (which correspond 
with actual physical address locations in the memory) and pass that data out over the 
network to which the computer system is connected. When this is encountered in user- 
level code, the peripheral hardware device must receive physical addresses in order to 
perform the data send command. Accordingly, whenever this function is encountered in 
user-level code, the microprocessor will perform a system call in order to convert the 
virtual addresses in the instruction set into physical addresses. These physical 
addresses are then passed to the peripheral device so that the peripheral device knows 
where (which physical addresses) to access the data from in the memory. Therefore, in 
this example, the virtual address locations from which the data is to be retrieved must 
be converted into actual physical address locations in the memory so the physical 
addresses can be transfer red to the peripheral hardware device (in this case, the 
Ethernet card), converts a logical address of data of the sending source in the 
communication command into a physical address, extracts transmission data from said 
main storage device the microprocessor will perform a system call in order to convert 
the virtual addresses in the instruction set into physical addresses. These physical 
addresses are then passed to the peripheral device so that the peripheral device knows 
where (which physical addresses) to access the data from in the memory. Therefore, in 
this example, the virtual address locations from which the data is to be retrieved must 
be converted into actual physical address locations in the memory so the physical 
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addresses can be transfer red to the peripheral hardware device (in this case, the 
Ethernet card)). Ang did not disclose produces a communication packet from the 
extracted data and the communication command and transmits the communication 
packet to the destination computer. The general concept of a communication packet 
from the extracted data and the communication command and transmits the 
communication packet to the destination computer is well known in the art as taught by 
Hayes. Hayes discloses a communication packet from the extracted data and the 
communication command and transmits the communication packet to the destination 
computer (Abstract The multiprocessor computer system includes at least two 
processors coupled to a packet-switched bus. Page table entries are removed from a 
plurality of TLBs in the multiprocessor computer system by first broadcasting a demap 
request packets on the packet -switched bus in response to one of the processors 
requesting that a page table entry be removed from its associated TLB. The demap 
request packet includes a virtual address and context information specifying this page 
table entry. Controllers reply to the demap request packet by sending a first reply packet 
to the controller that sent the original demap request packet to indicate receipt of the 
demap request packets. If a controller removes the page table entry from its associated 
TLB, that controller sends a second demap reply packet to indicate that the page table 
entry has been removed from its associated TLB. It would have been obvious to one of 
ordinary skill in the art at the time of the invention to modify Ang to include a 
communication packet from the extracted data and the communication command and 
transmits the communication packet to the destination computer in order to provide a 
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broadcast page removal scheme for all the processors on a multiprocessor computer 
system. 

Referring to claim 10 

Referring to claim 10 Ang, Luick, and Atzmony discloses all the limitations of claim 10, 
which is, describe above. Ang did not disclose wherein said reception section of said 
communication device receives a communication packet from said switched network, 
converts a destination logical address into a destination physical address for said main 
storage device and writes data in the communication packet into the destination 
physical address. The general concept of wherein said reception section of said 
communication device receives a communication packet from said switched network, 
converts a destination logical address into a destination physical address for said main 
storage device and writes data in the communication packet into the destination 
physical address is well known in the art as taught by Hayes. Hayes discloses wherein 
said reception section of said communication device receives a communication packet 
from said switched network (Col. 2 lines 27 - issuing a request packet by a first controller 
of the first TLB to remove the page table entry from the first TLB; sending the request 
packet to the packet-switched bus to be broadcast to a second controller coupled to a 
second TLB with the request packet specifying a predetermined source, the first 
address mode and process identification; receiving the request packet by the second 
controller on the packet-switched bus; checking by the second controller to determine 
whether the second TLB contains the page table entry by comparing the first mode 
address and process identification; completing any pending operations for the second 
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processor; removing the page table entry from the second TLB by the second controller 
if the page table entry is contained in the second TLB; issuing a reply packet by the 
second controller to indicate completion to the first controller; sending the reply Packet 
to the Packet-switched bus to be forwarded to the first controller with the reply packet 
identifying the source.) converts a destination logical address into a destination physical 
address for said main storage device and writes data in the communication packet into 
the destination physical address ( Col. 3 lines 13-21 Processor 1 10 is coupled to system 
bus 1 00 through cache controller 1 1 1 and bus watcher 112. Processor 1 1 0 also utilizes 
translation look aside buffer ("TLB") such as I/O TLB 1 14 or system TLB 1 13 to store its 
already translated virtual-to- physical address mapping in conjunction with its cache (not 
shown). Processors 120 and 130 are similarly coupled to system bus 100 through their 
respective cache controllers and bus watchers. When processor 110 needs to demap 
virtual-to- physical mapping for one or more virtual pages, its cache controller 1 1 1 
issues a broadcast demap request packet onto system bus 100 through bus watcher 
1 12. As other bus watchers 122 and 132 receive the demap request packet they 
forward the demap request packet to their respective cache controllers 121 and 131 for 
execution). It would have been obvious to one of ordinary skill in the art at the time of 
the invention to modify Ang to include wherein said reception section of said 
communication device receives a communication packet from said switched network, 
converts a destination logical address into a destination physical address for said main 
storage device and writes data in the communication packet into the destination 
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physical address in order to provide a broadcast page removal scheme for all the 
processors on a multiprocessor computer system. 

Referring to claim 11 

Referring to claim 1 1 , Ang, Luick, and Atzmony disclose all the limitations of claim 1 1 , 
which is described above. Ang also discloses wherein a destination computer number 
for setting a destination computer number for the communication command, a process 
number representative of a process of a communication opposite party for setting the 
destination process number of the communication command (Pg. 2 [0012] In a 
preferred embodiment, the present invention also tracks the total number of pages 
which are in use by peripheral devices, i.e., being written to or read from in the memory 
by a peripheral connected to the computer system in which the present invention is 
implemented. Pages which are in use per transaction or user-level job are "pinned 
down" and a total count of the number of pinned memory pages per transaction or user- 
level job is maintained in order to ensure that a single transaction or user-level job does 
not use too much memory space, thereby halting other processes from operating 
concurrently. In a preferred embodiment, total pages pinned counts per transaction or 
user-level job, as well as overall pinned pages counts system wide in the entire memory 
are maintained. These counts are compared to allowable transaction or user-level job 
maximum and overall system maximum values. In this way, no one transaction or user- 
level job has access to more than a predetermined maximum number of memory 
locations and the overall size of the memory allocated to concurrently executing 
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transactions may also be limited). Ang did not discloses a destination logical address 
representative of a writing destination of the data in the destination process for setting 
the destination logical address for the packet, a data length for setting a length of data 
of the packet, a sending source computer number for identification of a sending source 
for setting a sending source computer number of the communication command, the 
communication packet includes a command code for setting a communication 
command, and data to be written into destination. The general concept of a destination 
logical address representative of a writing destination of the data in the destination 
process for setting the destination logical address for the packet, a data length for 
setting a length of data of the packet, a sending source computer number for 
identification of a sending source for setting a sending source computer number of the 
communication command, the communication packet includes a command code for 
setting a communication command, and data to be written into destination is well known 
in the art as taught by Hayes. Hayes discloses a destination logical address 
representative of a writing destination of the data in the destination process for setting 
the destination logical address for the packet (Col. 3 lines 13-21 Processor 110 is 
coupled to system bus 100 through cache controller 1 1 1 and bus watcher 112. 
Processor 110 also utilizes translation look aside buffer ("TLB") such as I/O TLB 1 14 or 
system TLB 113 to store its already translated virtual-to- physical address mapping in 
conjunction with its cache (not shown). Processors 120 and 130 are similarly coupled to 
system bus 100 through their respective cache controllers and bus watchers. When 
processor 110 needs to demap virtual-to- physical mapping for one or more virtual 
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pages, its cache controller 1 1 1 issues a broadcast demap request packet onto system 
bus 100 through bus watcher 1 12. As other bus watchers 122 and 132 receive the 
demap request packet they forward the demap request packet to their respective cache 
controllers 121 and 131 for execution), a data length for setting a length of data of the 
packet, a sending source computer number for identification of a sending source for 
setting a sending source computer number of the communication command, the 
communication packet includes a command code for setting a communication 
command, and data to be written into destination. (Col. 2 lines 27 - issuing a request 
packet by a first controller of the first TLB to remove the page table entry from the first 
TLB; sending the request packet to the packet-switched bus to be broadcast to a 
second controller coupled to a second TLB with the request packet specifying a 
predetermined source, the first address mode and process identification; receiving the 
request packet by the second controller on the packet-switched bus; checking by the 
second controller to determine whether the second TLB contains the page table entry 
by comparing the first mode address and process identification; completing any pending 
operations for the second processor; removing the page table entry from the second 
TLB by the second controller if the page table entry is contained in the second TLB; 
issuing a reply packet by the second controller to indicate completion to the first 
controller; sending the reply Packet to the Packet-switched bus to be forwarded to the 
first controller with the reply packet identifying the source). It would have been obvious 
to one of ordinary skill in the art at the time of the invention to modify Ang to include a 
destination logical address representative of a writing destination of the data in the 
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destination process for setting the destination logical address for the packet, a data 
length for setting a length of data of the packet, a sending source computer number for 
identification of a sending source for setting a sending source computer number of the 
communication command, the communication packet includes a command code for 
setting a communication command, and data to be written into destination to provide a 
broadcast page removal scheme for all the processors on a multiprocessor computer 
system. 

Regarding claim 12 

Referring to claim 12 Ang, Luick, and Atzmony discloses all the limitations of claim 12 
which is described above. Ang did not discloses wherein the communication command 
further includes a communication command maximum simultaneous process number 
that indicates a number of processes simultaneously to a same destination, for 
transmission over the switched network, wherein when the communication command 
maximum simultaneous process number is two or more, the transmission section adds 
a command identification number indicative of an identification number of a command to 
be processed simultaneously to each of the communication packets to designate a 
translation lookaside buffer entry to be used by the reception section. The general 
concept of wherein the communication command further includes a communication 
command maximum simultaneous process number that indicates a number of 
processes simultaneously to a same destination, for transmission over the switched 
network, wherein when the communication command maximum simultaneous process 
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number is two or more, the transmission section adds a command identification number 
indicative of an identification number of a command to be processed simultaneously to 
each of the communication packets to designate a translation lookaside buffer entry to 
be used by the reception section is well known in the art as taught by Hayes. Hayes 
discloses wherein the communication command further includes a communication 
command maximum simultaneous process number that indicates a number of 
processes simultaneously to a same destination, for transmission over the switched 
network, wherein when the communication command maximum simultaneous process 
number is two or more, the transmission section adds a command identification number 
indicative of an identification number of a command to be processed simultaneously to 
each of the communication packets to designate a translation lookaside buffer entry to 
be used by the reception section. (Col.2 lines 27 - issuing a request packet by a first 
controller of the first TLB to remove the page table entry from the first TLB; sending the 
request packet to the packet-switched bus to be broadcast to a second controller 
coupled to a second TLB with the request packet specifying a predetermined source, 
the first address mode and process identification; receiving the request packet by the 
second controller on the packet-switched bus; checking by the second controller to 
determine whether the second TLB contains the page table entry by comparing the first 
mode address and process identification; completing any pending operations for the 
second processor; removing the page table entry from the second TLB by the second 
controller if the page table entry is contained in the second TLB; issuing a reply packet 
by the second controller to indicate completion to the first controller; sending the reply 
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Packet to the Packet-switched bus to be forwarded to the first controller with the reply 
packet identifying the source). It would have been obvious to one of ordinary skill in the 
art at the time of the invention to modify Ang to include the communication command 
further includes a communication command maximum simultaneous process number 
that indicates a number of processes simultaneously to a same destination, for 
transmission over the switched network, wherein when the communication command 
maximum simultaneous process number is two or more, the transmission section adds 
a command identification number indicative of an identification number of a command to 
be processed simultaneously to each of the communication packets to designate a 
translation lookaside buffer entry to be used by the reception section to provide a 
broadcast page removal scheme for all the processors on a multiprocessor computer 
system. 



Regarding claim 13 



Referring to claim 13 Ang, Luick, and Atzmony discloses all the limitations of claim 13 
which is described above. Ang did not discloses wherein the communication command 
further includes a communication command maximum simultaneous process number 
that indicates a number of processes simultaneously to a same destination, for 
transmission over the switched network, wherein when the communication command 
maximum simultaneous process number is two or more, the transmission section adds 
a command identification number indicative of an identification number of a command to 



Application/Control Number: 1 0/781 ,878 Page 31 

Art Unit: 2454 

be processed simultaneously to each of the communication packets to designate a 
translation lookaside buffer entry to be used by the reception section. The general 
concept of the communication command further includes a communication command 
maximum simultaneous process number that indicates a number of processes 
simultaneously to a same destination, for transmission over the switched network, 
wherein when the communication command maximum simultaneous process number is 
two or more, the transmission section adds a command identification number indicative 
of an identification number of a command to be processed simultaneously to each of the 
communication packets to designate a translation lookaside buffer entry to be used by 
the reception section is well known in the art as taught by Hayes. Hayes discloses the 
communication command further includes a communication command maximum 
simultaneous process number that indicates a number of processes simultaneously to a 
same destination, for transmission over the switched network, wherein when the 
communication command maximum simultaneous process number is two or more, the 
transmission section adds a command identification number indicative of an 
identification number of a command to be processed simultaneously to each of the 
communication packets to designate a translation lookaside buffer entry to be used by 
the reception section. (Col. 2 lines 27 - issuing a request packet by a first controller of 
the first TLB to remove the page table entry from the first TLB; sending the request 
packet to the packet-switched bus to be broadcast to a second controller coupled to a 
second TLB with the request packet specifying a predetermined source, the first 
address mode and process identification; receiving the request packet by the second 
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controller on the packet-switched bus; checking by the second controller to determine 
whether the second TLB contains the page table entry by comparing the first mode 
address and process identification; completing any pending operations for the second 
processor; removing the page table entry from the second TLB by the second controller 
if the page table entry is contained in the second TLB; issuing a reply packet by the 
second controller to indicate completion to the first controller; sending the reply Packet 
to the Packet-switched bus to be forwarded to the first controller with the reply packet 
identifying the source). It would have been obvious to one of ordinary skill in the art at 
the time of the invention to modify Ang to include the communication command further 
includes a communication command maximum simultaneous process number that 
indicates a number of processes simultaneously to a same destination, for transmission 
over the switched network, wherein when the communication command maximum 
simultaneous process number is two or more, the transmission section adds a 
command identification number indicative of an identification number of a command to 
be processed simultaneously to each of the communication packets to designate a 
translation lookaside buffer entry to be used by the reception section to provide a 
broadcast page removal scheme for all the processors on a multiprocessor computer 
system. 

Response to Arguments 
Applicant's arguments filed on 10/02/2008 have been fully considered but they are 
deemed moot in view of the new grounds of rejections. 
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Conclusion 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Ashley d. Turner whose telephone number is 571-270- 
1603. The examiner can normally be reached on Monday thru Friday 7:30a.m. - 
5:00p.m.. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Nathan Flynn can be reached at 571-272-1915. The fax phone number for 
the organization where this application or proceeding is assigned is 571-270-2603. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 
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